Ensure rendered exceptions take up minimal space#2089
Merged
patriksvensson merged 2 commits intospectreconsole:mainfrom Apr 15, 2026
Merged
Ensure rendered exceptions take up minimal space#2089patriksvensson merged 2 commits intospectreconsole:mainfrom
patriksvensson merged 2 commits intospectreconsole:mainfrom
Conversation
This was referenced Apr 16, 2026
This was referenced Apr 23, 2026
microsoft-github-policy-service Bot
pushed a commit
to Azure/bicep
that referenced
this pull request
Apr 24, 2026
Updated [Spectre.Console](https://github.com/spectreconsole/spectre.console) from 0.54.0 to 0.55.2. <details> <summary>Release notes</summary> _Sourced from [Spectre.Console's releases](https://github.com/spectreconsole/spectre.console/releases)._ ## 0.55.2 ## What's Changed * Support variation selectors, ZWJ sequences and surrogate pairs in length calculation by @fabsenet in spectreconsole/spectre.console#2082 * Add default value to selection prompt and multiselection prompt by @AntekOlszewski in spectreconsole/spectre.console#2079 ## New Contributors * @fabsenet made their first contribution in spectreconsole/spectre.console#2082 **Full Changelog**: spectreconsole/spectre.console@0.55.1...0.55.2 ## 0.55.1 ## What's Changed * Add tests to verify public API by @patriksvensson in spectreconsole/spectre.console#2073 * use StringComparer.OrdinalIgnoreCase as default comparer for TextPrompt by @AntekOlszewski in spectreconsole/spectre.console#2077 * Fix markup link rendering regression by @patriksvensson in spectreconsole/spectre.console#2084 * Add VS16 suffix to non-presentation emojis by @patriksvensson in spectreconsole/spectre.console#2087 * Ensure rendered exceptions take up minimal space by @patriksvensson in spectreconsole/spectre.console#2089 * Fix link parsing to terminate properly by @zhuman in spectreconsole/spectre.console#2091 ## New Contributors * @zhuman made their first contribution in spectreconsole/spectre.console#2091 **Full Changelog**: spectreconsole/spectre.console@0.55.0...0.55.1 ## 0.55.0 This release brings new features, performance improvements, bug fixes, and some important architectural changes. > [!CAUTION] > There are breaking changes in this release, so make sure you review the release notes and try things out before upgrading in production. ## New Spectre.Console.Ansi Library One of the biggest changes in this release is the introduction of [Spectre.Console.Ansi](https://www.nuget.org/packages/spectre.console.ansi), a new standalone library for writing ANSI escape sequences to the terminal without taking a full dependency on `Spectre.Console`. This makes it easy to add ANSI support to lightweight tools and libraries where pulling in the full Spectre.Console package would be overkill. Spectre.Console itself now depends on this library internally. We've also added some nice convenience methods for the .NET Console class: ```csharp using Spectre.Console.Ansi; Console.Markup("[yellow]Hello[/] "); Console.MarkupLine("[blue]World[/]"); Console.Ansi(writer => writer .BeginLink("https://spectreconsole.net", linkId: 123) .Decoration(Decoration.Bold | Decoration.Italic) .Foreground(Color.Yellow) .Write("Spectre Console") .ResetStyle() .EndLink()); ``` ## Style Is Now a Struct `Style` has been converted from a class to a struct, and link/URL information has been extracted into a separate `Link` type. This improves allocation performance, especially in rendering-heavy scenarios, but is a breaking change for code that relies on reference semantics. ## Progress Improvements The `Progress` widget received a lot of love in this release. It now uses `TimeProvider` instead of the wall clock, making it significantly easier to write deterministic tests. `ProgressTask` has a new `Tag` property for attaching arbitrary metadata, and you can now override the global hide-when-completed behavior on individual tasks. Tasks can also be removed from the progress context entirely. Speed calculations have been improved with configurable max sampling age and ... (truncated) Commits viewable in [compare view](spectreconsole/spectre.console@0.54.0...0.55.2). </details> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details> ###### Microsoft Reviewers: [Open in CodeFlow](https://microsoft.github.io/open-pr/?codeflow=https://github.com/Azure/bicep/pull/19497) --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: brendandburns <5751682+brendandburns@users.noreply.github.com>
This was referenced Apr 25, 2026
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Fixes #1844
Changes
The generated renderable that contains the exception information was set to expand to the maximum terminal area. This pull request changes the behavior to instead use as little space as possible.
Also made exceptions easier to test by adding an
ExceptionInfoResolverthat gets theexception information used when rendering an exception. This way, we do not have to
do manual exception scrubbing of the output (that messes up rendering).
Please upvote 👍 this pull request if you are interested in it.